import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import ElementUI, { Message } from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import axios from 'axios'
import '@/assets/global.less'

axios.defaults.baseURL = 'http://www.liulongbin.top:3008'
Vue.prototype.$axios = axios

axios.interceptors.request.use(function (config) {
  const token = store.state.user.token
  console.log(store)
  if (token) {
    config.headers.Authorization = token
  }
  return config
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

axios.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  // console.log('我拿到了数据')
  return response
}, function (error) {
  // console.log('我报错了')
  // 对响应错误做点什么
  console.log(error)
  if (error.response.status === 401) {
    // 清空 token
    store.commit('user/updateToken', '')

    // 跳转到登录页
    // this.$router.push
    router.push('/login')

    // 提醒用户 token 已过期
    Message.error(error.response.data.message)
  }
  return Promise.reject(error)
})

Vue.config.productionTip = false
Vue.use(ElementUI)
new Vue({

  router,
  store,
  render: h => h(App)
}).$mount('#app')
